

### **Analog Interfacing**

### ARM Cortex-M4 Microcontroller

- ADC on TM4C123G Microcontroller
- GPIO Pins Mapping for ADC
- ADC Block Diagram
- Configuration Steps for ADC Module
  - ADC Clock Gating Control Configuration
  - GPIO Configuration as ADC input
  - ADC Module Configuration
  - ADC Sample Sequencer Configuration
  - ADC Interrupt Configuration

### **ADC Details**

- TM4C123 Microcontroller contains 2 successive approximation-based ADCs
- Each ADC can operate independently with following features:
  - Maximum sampling rate of 1 Msps
  - 12-bit sample resolution
  - 12 external AI channels (ANI\_0 to ANI\_11)
  - 1 internal temperature sensor
  - Multiple triggering sources for starting process
  - Single ended or differential analog inputs
  - Hardware sample averaging capability up 64 samples
- Four programmable sample sequencers (SS0, SS1, SS2, SS3)
  - enable flexible sampling of multiple Al
  - reduces microcontroller overhead to handle each conversion

# **GPIO Pins Mapping for ADC**

| #  | Analog Input Channel | GPIO Pin Assignment |
|----|----------------------|---------------------|
| 1  | ANI_0                | Port E pin 3 (PE3)  |
| 2  | ANI_1                | Port E pin 2 (PE2)  |
| 3  | ANI_2                | Port E pin 1 (PE1)  |
| 4  | ANI_3                | Port E pin 0 (PE0)  |
| 5  | ANI_4                | Port D pin 3 (PD3)  |
| 6  | ANI_5                | Port D pin 2 (PD2)  |
| 7  | ANI_6                | Port D pin 1 (PD1)  |
| 8  | ANI_7                | Port D pin 0 (PD0)  |
| 9  | ANI_8                | Port E pin 5 (PE5)  |
| 10 | ANI_9                | Port E pin 4 (PE4)  |
| 11 | ANI_10               | Port B pin 4 (PB4)  |
| 12 | ANI_11               | Port B pin 5 (PB5)  |

# **ADC Block Diagram**



### TM4C123 Microcontroller

### Five steps process

- Step 1: ADC Clock Gating Control Configuration
- Step 2: GPIO Configuration as ADC input
- Step 3: ADC Module Configuration
- Step 4: ADC Sample Sequencer Configuration
- Step 5: ADC Interrupt Configuration

### TM4C123 Microcontroller

#### Step 1: ADC Clock Gating Control Config.

Step 2: GPIO Config. as ADC input

Step 3: ADC Module Configuration

Step 4: ADC Sample Sequencer Config.

- Run Mode Clock Gating Control Register RCGC\_ADC\_R
   (Address Value = 0x400FE638) is used to enable clock to
   ADC modules
- Bit 0 of RCGC\_ADC\_R corresponds to ADC0 module, while bit 1 to corresponds ADC1 module
- Writing 1 to the bit enables and provides clock to corresponding ADC module
- After clock enabling, 3-clock cycles delay required before accessing the ADC register
- e.g. writing 0x02 to RCGC\_ADC\_R will enable clock on ADC1 module

#### TM4C123 Microcontroller

Step 1: ADC Clock Gating Control Config.

#### Step 2: GPIO Config. as ADC input

Step 3: ADC Module Configuration

Step 4: ADC Sample Sequencer Config.

- 12 analog inputs (ANI\_0 to ANI\_11) to TM4C123
   Microcontroller are multiplexed to GPIO pins
- To enable analog functionality on a GPIO Pin
  - Enable clock on GPIO using RCGC\_GPIO\_R (Address Value = 0x400FE608)
  - Disable digital function by clearing corresponding bit in GPIO\_DEN\_R (Offset Value = 0x51C)
  - Set corresponding bit in *GPIO Analog Mode Select Register* **GPIO\_AMSEL\_R** (*Offset Value = 0x528*) to enable analog (by disabling analog isolation circuit)
- e.g. for configuring PortB (Base Address = 0x40005000) pin 4 (ANI\_10) as an ADC analog input we will clear bit 4 in GPIO\_DEN\_R and set it in GPIO\_AMSEL\_R

TM4C123 Microcontroller

### **GPIO Port Configurations**

| # | Configuration                    | Register     | Offset | Register<br>Address | Configuration Setting                             |
|---|----------------------------------|--------------|--------|---------------------|---------------------------------------------------|
| 1 | <b>GPIO Clock Gating Control</b> | RCGC_GPIO_R  | -      | 0x400FE608          | Set bit to enable clock on GPIO Port              |
| 2 | Pad Control Config.              | GPIO_DEN_R   | 0x51C  | -                   | Clear bit to disable digital function of GPIO Pin |
| 3 | Analog Mode Select               | GPIO_AMSEL_R | 0x528  | -                   | Set the bit to enable analog mode                 |

### TM4C123 Microcontroller

Step 1: ADC Clock Gating Control Config.

Step 2: GPIO Config. as ADC input

#### Step 3: ADC Module Configuration

Step 4: ADC Sample Sequencer Config.

Step 5: ADC Interrupt Configuration

The key configuration steps for an ADC Module are:

- Clock Source Config.
- Sampling Rate Config.
- Sequencer Triggering Source Config.
- Sequencer Priority Config.
- Hardware Averaging Config.
- Control Config.

### TM4C123 Microcontroller

Step 1: ADC Clock Gating Control Config.

Step 2: GPIO Config. as ADC input

#### Step 3: ADC Module Configuration

- ☐ Clock Source Config.
- ☐ Sampling Rate Config.
- ☐ Sequencer Triggering Source Config.
- Sequencer Priority Config.
- Hardware Averaging Config.
- ☐ ADC Control Config.
- Step 4: ADC Sample Sequencer Config.
- Step 5: ADC Interrupt Configuration

- 4 LSB of Clock Source Configuration Register ADC\_CLK\_CONFIG\_R (Offset Value = 0xFC8) are used for ADC clock source selection.
- For a value of 0, the system clock is used for sampling
- For a value of 1, precision internal oscillator (*PIOSC*) running at 16 MHz as clock source and the ADC module can continue to operate in Deep-Sleep Mode

Seems useful in Interrupt based systems

### TM4C123 Microcontroller

- Step 1: ADC Clock Gating Control Config.
- Step 2: GPIO Config. as ADC input

- ☐ Clock Source Config.
- Sampling Rate Config.
- Sequencer Triggering Source Config.
- Sequencer Priority Config.
- ☐ Hardware Averaging Config.
- ADC Control Config.
- Step 4: ADC Sample Sequencer Config.
- Step 5: ADC Interrupt Configuration

- ADC sampling rate is configured using ADC Peripheral Configuration Register ADC\_PERI\_CONFIG\_R (Offset Value = 0xFC4)
- Only these values can be configured by using this register
  - **0x01**: configures **125** ksps sample rate
  - 0x03: configures 250 ksps sample rate
  - 0x05: configures 500 ksps sample rate
    - **0x07**: configures **1000 ksps** (1 Msps) sample rate (default value)
- When attempt, to configure ADC with sample rate not supported by the device, is made then ADC either continue with default or more recently used sample rate

### TM4C123 Microcontroller

Step 1: ADC Clock Gating Control Config.

Step 2: GPIO Config. as ADC input

- ☐ Clock Source Config.
- ☐ Sampling Rate Config.
- Sequencer Triggering Source Config.
- ☐ Sequencer Priority Config.
- ☐ Hardware Averaging Config.
- ADC Control Config.
- Step 4: ADC Sample Sequencer Config.
- Step 5: ADC Interrupt Configuration

- Each ADC sequencer can be triggered by processor, GPIO, timer, PWM or comparator
- ADC Event Multiplexer Select Register ADC\_E\_MUX\_R
   (Offset Value = 0x014) can be configured for selection
- Using different triggering sources at different rates for Sample Sequencer allow to sample analog inputs at different sampling rates
- Each triggering source has its own register for triggering the sample sequencer
  - ADC\_PROC\_INIT\_SS\_R (Offset Value = 0x028): when using Processor as triggering source
  - ADC\_PWM\_TRIGGER\_R (Offset Value = 0x01C): used when triggering source is PWM

### TM4C123 Microcontroller

Step 1: ADC Clock Gating Control Config.

Step 2: GPIO Config. as ADC input

- ☐ Clock Source Config.
- Sampling Rate Config.
- Sequencer Triggering Source Config.
- Sequencer Priority Config.
- Hardware Averaging Config.
- ADC Control Config.
- Step 4: ADC Sample Sequencer Config.
- Step 5: ADC Interrupt Configuration



| Bit field                                     | Description                                                                                                                                                                                                         |
|-----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SS0 Trigger<br>Mux, SS1 Trig-<br>ger Mux, SS2 | Each of these bit fields selects the triggering source for the corresponding<br>sample sequencer. The configurable values for these bit fields and the<br>resulting selections for ADC triggering are listed below. |
| Trigger Mux,<br>SS3 Trigger<br>Mux            | <ul> <li>Configuring a value of 0 makes the processor as ADC triggering<br/>source.</li> </ul>                                                                                                                      |
| Mux                                           | <ul> <li>Configuring a value of 1 or 2 makes the analog comparator 0 or 1 as<br/>the trigger source using analog comparator control configuration.</li> </ul>                                                       |
|                                               | <ul> <li>Configuring a value of 4 makes the GPIO pin as the trigger source</li> </ul>                                                                                                                               |
|                                               | <ul> <li>Configuring a value of 5 makes the timer as the trigger source. To<br/>use timer as trigger source timer output trigger enable bit must be<br/>set.</li> </ul>                                             |
|                                               | <ul> <li>Configuring a value of 6, 7, 8 or 9 makes the PWM generator 0, 1<br/>2 or 3 as trigger source.</li> </ul>                                                                                                  |
|                                               | <ul> <li>Configuring a value of 0xF enables continuous sampling mode<br/>which does not require triggering.</li> </ul>                                                                                              |

### TM4C123 Microcontroller

Step 1: ADC Clock Gating Control Config.

Step 2: GPIO Config. as ADC input

- ☐ Clock Source Config.
- Sampling Rate Config.
- ☐ Sequencer Triggering Source Config.
- **☐** Sequencer Priority Config.
- ☐ Hardware Averaging Config.
- ☐ ADC Control Config.
- Step 4: ADC Sample Sequencer Config.
- Step 5: ADC Interrupt Configuration

- Order of sampling among the active sequencers is decided based on assigned priority
- Each active sequencers should be assigned a unique priority using ADC Sample Sequencer Priority Register ADC\_PRI\_SS\_R (Offset Value = 0x020)
- Out of reset, Sequencer 0 has the highest priority, and Sequencer
   3 has the lowest priority.
- When reconfiguring sequence priorities, each sequence must have a unique priority for the ADC to operate properly



| Bit field |           | Description                                                                 |  |  |  |
|-----------|-----------|-----------------------------------------------------------------------------|--|--|--|
| SS0       | Priority, | All the sequencer priority bit fields follow a common definition. Configur- |  |  |  |
| SS1       | Priority, | ing a value of 0 makes the corresponding sequencer highest priority, while  |  |  |  |
| SS2       | Priority, | a value of 3 corresponds to lowest priority.                                |  |  |  |
| SS3 I     | Priority  |                                                                             |  |  |  |

### TM4C123 Microcontroller

Step 1: ADC Clock Gating Control Config.

Step 2: GPIO Config. as ADC input

#### Step 3: ADC Module Configuration

- ☐ Clock Source Config.
- Sampling Rate Config.
- Sequencer Triggering Source Config.
- Sequencer Priority Config.
- Hardware Averaging Config.
- ADC Control Config.

Step 4: ADC Sample Sequencer Config.

- Hardware averaging is used for improved resolution
- ADC performs over sampling to average multiple samples
- ADC Sample Averaging Control Register ADC\_SAC\_R (Offset Value = 0x030) is used to configure magnitude of hardware averaging
- Only bit 0-2 of this register can be written as following
  - 0x0 : No hardware oversampling
  - **0x1**: 2x hardware oversampling
  - **0x2**: 4x hardware oversampling
  - 0x3 : 8x hardware oversampling
  - **0x4**: 16x hardware oversampling
  - **0x5**: 32x hardware oversampling
  - **0x6**: 64x hardware oversampling

### TM4C123 Microcontroller

Step 1: ADC Clock Gating Control Config.

Step 2: GPIO Config. as ADC input

#### Step 3: ADC Module Configuration

- ☐ Clock Source Config.
- □ Sampling Rate Config.
- Sequencer Triggering Source Config.
- ☐ Sequencer Priority Config.
- Hardware Averaging Config.
- ADC Control Config.

Step 4: ADC Sample Sequencer Config.

- Choice of ADC voltage reference source using ADC Control Register ADC\_CONTROL\_R (Offset Value = 0x038)
  - Set bit 0 to enable voltage at analog supply pins VddA & GndA as reference voltage
  - Values set in this register apply to both ADC modules
- Enable or disable each sample sequencer individually using ADC Active Sample Sequencer Register ADC\_ACTIVE\_SS\_R (Offset Value = 0x000)
  - Bit 0 to 3 corresponds to SS0 to SS3
  - Setting a bit to 1 enables the corresponding sample sequencer
  - Bit 16 (read only) of the register reads 1 if the ADC is busy

### TM4C123 Microcontroller

### **ADC Module Configurations**

- ADC0 base address: 0x40038000 & ADC1 base address: 0x40039000
- Step 1: Enable ADC Clock using **RCGC\_ADC\_R** (address value 0x400FE638)
  - writing 1 (to bit 0 for ADC0 and bit 1 for ADC1)

| # | Configuration                  | Register          | Offset | Configuration Setting                                       |
|---|--------------------------------|-------------------|--------|-------------------------------------------------------------|
| 2 | ADC Peripheral Config.         | ADC_PERI_CONFIG_R | 0xFC4  | Set ADC sample rate by writing predefined value             |
| 3 | ADC Event Mux. Select          | ADC_E_MUX_R       | 0x014  | Select ADC trigger by writing predefined value              |
| 4 | ADC Sample Sequencer Priority  | ADC_PRI_SS_R      | 0x020  | Write 0 for highest and 3 for lowest priority               |
| 5 | ADC Sample Averaging Control   | ADC_SAC_R         | 0x030  | Select hardware averaging level by writing predefined value |
| 6 | ADC Control Register           | ADC_CONTROL_R     | 0x038  | Select the voltage reference for ADC                        |
| 7 | ADC Active SS Register         | ADC_ACTIVE_SS_R   | 0x000  | Enable individual SS by setting corresponding bit           |
| 8 | ADC Triggering Source Register | -                 | -      | Register selected based on <b>Step 3</b>                    |

### TM4C123 Microcontroller

- Step 1: ADC Clock Gating Control Config.
- Step 2: GPIO Config. as ADC input
- Step 3: ADC Module Configuration
  - ☐ Clock Source Config.
  - Sampling Rate Config.
  - ☐ Sequencer Triggering Source Config.
  - Sequencer Priority Config.
  - Hardware Averaging Config.
  - ADC Control Config.

### Step 4: ADC Sample Sequencer Config.

- Each Sample Sequencer (SS) can be configured independently using its associated registers
  - Selection of an analog input channel is completely independent and can be performed separately
  - Same analog input can be configured for multiple channels of the same SS
  - Sample sequencer analog input can be configured as single ended or differential type
  - Not necessary to use all the channels of a sample sequencer
- Always disable the appropriate sample sequencer before modifying the ADC configurations

### TM4C123 Microcontroller

- Step 1: ADC Clock Gating Control Config.
- Step 2: GPIO Config. as ADC input
- Step 3: ADC Module Configuration
  - ☐ Clock Source Config.
  - ☐ Sampling Rate Config.
  - Sequencer Triggering Source Config.
  - ☐ Sequencer Priority Config.
  - Hardware Averaging Config.
  - ☐ ADC Control Config.

### Step 4: ADC Sample Sequencer Config.

- Input Multiplexing Config.
- Sequencer Control Config.
- ☐ Sample Sequencer Result
- Step 5: ADC Interrupt Configuration

- Analog inputs to ADC sequencer can be configured using ADC Sample Sequencer Input Multiplexer Register (ADC\_SSxIN\_MUX\_R, where x represents the sequencer number and can be 0 to 3)
  - ADC\_SSOIN\_MUX\_R (Offset Value = 0x040) 8 channels
  - ADC\_SS1IN\_MUX\_R (Offset Value = 0x060) 4 channels
  - ADC\_SS2IN\_MUX\_R (Offset Value = 0x080) 4 channels
  - ADC\_SS3IN\_MUX\_R (Offset Value = 0x0A0) 1 channel



| Bit field                  | Description                                                                                                                                                                                                                                                                                                                                          |
|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Input7 Mux -<br>Input0 Mux | Each of these bit fields is used to configure an analog input channel for<br>the corresponding sequencer. Configuring a value of 2 to bit field Input0<br>Mux, assigns analog input channel 2 as the first input to the sequencer 0.<br>The possible values that can be configured are 0 to 11, which correspond<br>to the 12 analog input channels. |

- Step 1: ADC Clock Gating Control Config. Step 2: GPIO Config. as ADC input Step 3: ADC Module Configuration Clock Source Config. Sampling Rate Config. Sequencer Triggering Source Config. Sequencer Priority Config. Hardware Averaging Config. ADC Control Config. Step 4: ADC Sample Sequencer Config. Input Multiplexing Config. Sequencer Control Config. Sample Sequencer Result Step 5: ADC Interrupt Configuration
- ADC Sample Sequencer Control Register (ADC\_SSx\_CONTROL\_R, where x represents the sequencer number and can be 0 to 3) contains the configuration information for a sample executed with Sample Sequencer
  - ADC\_SSO\_CONTROL\_R (Offset Value = 0x044) 8 channels
  - ADC\_SS1\_CONTROL\_R (Offset Value = 0x064) 4 channels
  - **ADC\_SS2\_CONTROL\_R** (Offset Value = 0x084) 4 channels
  - ADC\_SS3\_CONTROL\_R (Offset Value = 0x0A4) 1 channel
- For example, SS3 can be configured for the following settings
  - Bit 0 (D0): Sample Differential Input Select
    - Set to consider analog input as differential input
  - Bit 1 (END0): End of Sequence
    - 1 means end of sequence and 0 means sampling and conversion continues
  - Bit 2 (IE0): Sample Interrupt Enable
    - When set, interrupt signal is asserted at the end of sample's conversion
  - Bit 3 (TS0): 1<sup>st</sup> Sample Temperature Sensor Select
    - If set, read the internal temperature sensor during first sample of SS
- When configuring a sample sequencer, END bit must be set.

### TM4C123 Microcontroller

- Step 1: ADC Clock Gating Control Config. Step 2: GPIO Config. as ADC input Step 3: ADC Module Configuration Clock Source Config. Sampling Rate Config. Sequencer Triggering Source Config. Sequencer Priority Config. Hardware Averaging Config. ADC Control Config. Step 4: ADC Sample Sequencer Config. Input Multiplexing Config.
- ADC Sample Sequencer Result FIFO
   (ADC\_SSx\_FIFO\_DATA\_R, where x represents the sequencer number and can be 0 to 3) contains the conversion results for Sample Sequencer
  - ADC\_SSO\_FIFO\_DATA\_R (Offset Value = 0x048) 8 channels
  - ADC\_SS1\_ FIFO\_DATA \_R (Offset Value = 0x068) 4 channels
  - ADC\_SS2\_ FIFO\_DATA \_R (Offset Value = 0x088) 4 channels
  - ADC\_SS3\_ FIFO\_DATA \_R (Offset Value = 0x0A8) 1 channel
- This register contains 12-bit conversion result of sample
- Reads of this register return conversion result data in the order sample 0, sample 1, and so on, until the FIFO is empty

Step 5: ADC Interrupt Configuration

Sequencer Control Config.

Sample Sequencer Result

### TM4C123 Microcontroller

### Sample Sequencer Configurations

ADC0 base address: 0x40038000

• ADC1 base address: 0x40039000

| Register label        | Offset | Reset value | Brief description                    |
|-----------------------|--------|-------------|--------------------------------------|
| ADC_SS0_IN_MUX_R      | 0x040  | 0x00000000  | SS0 analog input selection register. |
| ADC_SS0_CONTROL_R     | 0x044  | 0x00000000  | SS0 control register.                |
| ADC_SS0_FIFO_DATA_R   | 0x048  |             | SS0 FIFO data register.              |
| ADC_SS0_FIFO_STATUS_R | 0x04C  | 0x00000100  | SS0 FIFO status register.            |
| ADC_SS1_IN_MUX_R      | 0x060  | 0x00000000  | SS1 analog input selection register. |
| ADC_SS1_CONTROL_R     | 0x064  | 0x00000000  | SS1 control register.                |
| ADC_SS1_FIFO_DATA_R   | 0x068  | -           | SS1 FIFO data register.              |
| ADC_SS1_FIFO_STATUS_R | 0x06C  | 0x00000100  | SS1 FIFO status register.            |
| ADC_SS2_IN_MUX_R      | 0x080  | 0x00000000  | SS2 analog input selection register. |
| ADC_SS2_CONTROL_R     | 0x084  | 0x00000000  | SS2 control register.                |
| ADC_SS2_FIFO_DATA_R   | 0x088  | -           | SS2 FIFO data register.              |
| ADC_SS2_FIFO_STATUS_R | 0x08C  | 0x00000100  | SS2 FIFO status register.            |
| ADC_SS3_IN_MUX_R      | 0x0A0  | 0x00000000  | SS3 analog input selection register. |
| ADC_SS3_CONTROL_R     | 0x0A4  | 0x00000000  | SS3 control register.                |
| ADC_SS3_FIFO_DATA_R   | 0x0A8  | -           | SS3 FIFO data register.              |
| ADC_SS3_FIFO_STATUS_R | 0x0AC  | 0x00000100  | SS3 FIFO status register.            |

### TM4C123 Microcontroller

- Step 1: ADC Clock Gating Control Config.
- Step 2: GPIO Config. as ADC input
- Step 3: ADC Module Configuration
  - ☐ Clock Source Config.
  - Sampling Rate Config.
  - Sequencer Triggering Source Config.
  - Sequencer Priority Config.
  - Hardware Averaging Config.
  - ADC Control Config.
- Step 4: ADC Sample Sequencer Config.
  - ☐ Input Multiplexing Config.
  - Sequencer Control Config.
  - ☐ Sample Sequencer Result

- Each AI channel interrupt configuration can be performed separately by using ADC Sequencer Control Configuration Register
- Each Sample Sequencer can also be a source of interrupt that can be configured using ADC Interrupt Control Register
- 4 LSB of below registers are used for masking, status, and clearing of interrupts from the four sequencers

| Register label | Offset | Reset value | Brief description                                                                            |
|----------------|--------|-------------|----------------------------------------------------------------------------------------------|
| ADC_RIS_R      | 0x004  | 0x000000000 | Interrupt mask register. Interrupt raw status register. Interrupt status and clear register. |

# THANK YOU

Any Questions???